import Vue from 'vue'
import VueRouter from 'vue-router'
import routes from "@/router/routes";
import NProgress from "nprogress"
import store from "@/store/index"
import util from "@/libs/util";

const router = new VueRouter({
  mode: 'history',
  base: process.env.BASE_URL,
  routes
})

// fix vue-router NavigationDuplicated
const VueRouterPush = VueRouter.prototype.push
VueRouter.prototype.push = function push(location) {
  return VueRouterPush.call(this, location).catch(err => err)
}
const VueRouterReplace = VueRouter.prototype.replace
VueRouter.prototype.replace = function replace(location) {
  return VueRouterReplace.call(this, location).catch(err => err)
}
Vue.use(VueRouter)

/**
 * 路由拦截
 * 权限验证
 */
router.beforeEach(async (to, from, next) => {

  NProgress.start()
   // 验证当前路由所有的匹配中是否需要有登录验证的
   if (to.matched.some(r => r.meta.auth)) {
    // 这里暂时将cookie里是否存有token作为验证是否登录的条件
    // 请根据自身业务需要修改
    const token = util.cookies.get('token')
    if (token && token !== 'undefined') {
      next()
    } else {
      // 没有登录的时候跳转到登录界面
      // 携带上登陆成功之后需要跳转的页面完整路径
      next({
        name: 'login',
        query: {
          redirect: to.fullPath
        }
      })
      // https://github.com/d2-projects/d2-admin/issues/138
      NProgress.done()
    }
  } else {
    // 不需要身份校验 直接通过
    next()
  }
})

router.afterEach(to => {
  // 进度条
  NProgress.done()
  // 多页控制 打开新的页面
  // store.dispatch('d2admin/page/open', to)
  // 更改标题
  // util.title(to.meta.title)
})

export default router
